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SPECIFICATION 

IBM Docket No. STL920000062US 1 

TO ALL WHOM IT MAY CONCERN: 

BE IT KNOWN that We, Howard J. Glaser of San Jose, California and citizen of the United 
States, Laurence E. England of Morgan Hill, California and citizen of the United States, 
Rebecca Lau Poole of San Jose, California and citizen of the United States, and Chenhong Xia 
of San Jose, California and resident of the United States, have invented new and useful 
improvements in 



METHOD, SYSTEM, COMPUTER PROGRAM PRODUCT, AND ARTICLE OF 
MANUFACTURE FOR INSTALLATION AND CONFIGURATION OF A COMPUTER 
PROGRAM ACCORDING TO A STORED CONFIGURATION 

of which the following is a specification: 



STL920000062US1 



1 



* 
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2 

3 METHOD, SYSTEM, COMPUTER PROGRAM PRODUCT, AND ARTICLE OF 

4 MANUFACTURE FOR INSTALLATION AND CONFIGURATION OF A COMPUTER 

5 PROGRAM ACCORDING TO A STORED CONFIGURATION 

6 
7 
8 

9 CROSS-REFERENCE TO RELATED APPLICATIONS 

10 
11 

12^ Application Serial Number , filed concurrently herewith on October 12, 

1 a 3 2000 for METHOD, SYSTEM, COMPUTER PROGRAM PRODUCT, AND ARTICLE OF 

I4g MANUFACTURE FOR DOWNLOADING A COMPUTER PROGRAM ACCORDING TO A 

lfl STORED CONFIGURATION (IBM Docket STL920000091), currently co-pending, and 

Id J assigned to the same assignee as the present invention; and 

1% Application Serial Number , filed concurrently herewith on October 12, 

1 %Z 2000 for METHOD, SYSTEM, COMPUTER PROGRAM PRODUCT, AND ARTICLE OF 

19* MANUFACTURE FOR UPDATING A COMPUTER PROGRAM ACCORDING TO A 

2d3 STORED CONFIGURATION (IBM Docket STL920000092), currently co-pending, and 

2t° assigned to the same assignee as the present invention. 

22 The foregoing co-pending applications are incorporated herein by reference. 

23 
24 

25 A portion of the Disclosure of this patent document contains material which is subject 

26 to copyright protection. The copyright owner has no objection to the facsimile reproduction by 

27 anyone of the patent document or the patent disclosure, as it appears in the Patent and 

28 Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. 
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1 

2 BACKGROUND OF THE INVENTION 

3 
4 

5 1. Field of the Invention 

6 

7 The present invention relates in general to computer programs, and more particularly to 

8 remote installation of a computer program. 
9 

10 

11 2. Description of the Related Art 

12=* 

13 ;f Customers and providers may have a number of requirements in installing or deploying 

14o an application program. 

15 r! 

Customers may prefer to remotely install application program clients from a central 

IX server(s) in order to increase both installation productivity and maintenance productivity. Thin 

18U clients may be preferred as thin clients generally require less workstation customization, 

19^ perhaps as little as a browser with the appropriate option settings and plugins. Preferably, users 

20p should be able to move between different workstations, and still be able to access their tools 

2r Sf and data, another potential advantage of a thin client. A customer may prefer to control which 

22 application programs and which versions of the application programs are available to a 

23 particular user. In addition to controlling the application programs, a customer may wish to 

24 control access to resources and assets based upon a user's responsibilities and roles in an 

25 organization. Alternatively, the customer may wish to control and filter project work views 

26 based on the user's responsibilities and roles. In addition to such central control, the customer 

27 may want an inventory of the application programs (including versions) installed and used on a 

28 workstation or a group of workstations without the need to go to each user workstation. 
29 
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1 An application program provider may also have a number of similar requirements in 

2 installing or deploying an application program. The provider may also want for licensing 

3 purposes the inventory of the application programs (including versions) installed and used on a 

4 workstation or a group of workstations without the need to go to each user workstation. To 

5 satisfy a customer's specific individual requirements, the provider would prefer a mechanism 

6 for configuring the application program to support a customer solution which may be tailored 

7 by the customer to suit the customers needs, such as role-based views. 
8 

9 Conventional systems and methods have failed to provide all of the above advantages. 

10 Thus, there is a clearly felt need for a method, system, article of manufacture, and computer 

1 1 program product for providing remote installation and deployment with these advantages. 
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1 SUMMARY OF THE INVENTION 

2 

3 The present invention comprises a method, system, article of manufacture, and a 

4 computer program product for providing remote installation of an application program. A 

5 configuration of the application program corresponding to a particular user of the local 

6 application is defined and stored on a remote server. In response to a user request, a 

7 determination is made that the stored configuration corresponds to the requesting user, the user 

8 is authenticated, and data is downloaded from the remote server according to the stored 

9 configuration. This stored configuration is also encrypted and stored in a manifest file which is 

10 also downloaded. Responsive to the user authentication, the manifest file is decrypted, and the 

1 1 application program is constructed pursuant to the configuration decrypted from the manifest 
12 : , file. 

ia3 

14[) One aspect of a preferred embodiment of the present invention defines a configuration 

15,2 of an application program corresponding to a particular user of the application program. 
Id J 

17, Another aspect of a preferred embodiment of the present invention stores the 

1^; configuration on a remote server executing on a remote data processing system. 
19± 

2Q j Another aspect of a preferred embodiment of the present invention initiates a session 

2F~ between the local data processing system and the remote data processing system in response to 

22 the user requesting the application program. 
23 

24 Another aspect of a preferred embodiment of the present invention authenticates the 

25 user in response to the user request. 
26 

27 Another aspect of a preferred embodiment of the present invention determines that the 

28 stored configuration corresponds to the requesting user. 
29 
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1 Another aspect of a preferred embodiment of the present invention downloads data 

2 from the remote data processing system to the local data processing system according to the 

3 stored configuration. 
4 

5 Another aspect of a preferred embodiment of the present invention encrypts the stored 

6 configuration into a manifest file. 
7 

8 Another aspect of a preferred embodiment of the present invention downloads the 

9 manifest file from the remote data processing system to the local data processing system. 
10 

1 1 Another aspect of a preferred embodiment of the present invention authenticates the 

12^ user in response to the user requesting a build of the application program. 

14f a Another aspect of a preferred embodiment of the present invention decrypts the 

15 ; :~; manifest file in response to the user authentication. 

1% Another aspect of a preferred embodiment of the present invention builds the 

18U application program pursuant to the configuration decrypted from the manifest file. 

2CO The present invention has the advantage of providing improved remote installation of a 

2 F " computer program. 

22 

23 The present invention has the further advantage of providing a remote install of an 

24 application program client from a central server(s) in order to increase installation productivity 

25 and maintenance productivity. 
26 

27 The present invention has the further advantage of providing thin clients which 

28 generally require less workstation customization. 
29 
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1 The present invention has the further advantage of allowing a user to be able to move 

2 between different workstations, and still be able to access the user's tools and data. 
3 

4 The present invention has the further advantage of providing control over which 

5 application programs and which versions of the application programs are available to a 

6 particular user. 
7 

8 The present invention has the further advantage of providing control over access to 

9 resources and assets based upon a user's responsibilities and roles in an organization. 
10 

1 1 The present invention has the further advantage of providing control and filtering of 

1%^ project work views based on the user's responsibilities and roles. 

13^2 

14f q The present invention has the further advantage of providing an inventory of the 

application programs (including versions) installed and used on a workstation or a group of 

lgjiy workstations without the need to go to each user workstation. 
ITT 

18jl The present invention has the further advantage of providing for licensing purposes the 

19^ inventory of the application programs (including versions) installed and used on a workstation 

2Qrj or a group of workstations without the need to go to each user workstation. 

22 The present invention has the further advantage of allowing a user to configure the 

23 application program to support a customer solution which may be tailored by the customer to 

24 suit the customers needs, such as role-based views. 
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1 BRIEF DESCRIPTION OF THE DRAWINGS 

2 

3 For a more complete understanding of the present invention and the advantages thereof, 

4 reference is now made to the Description of the Preferred Embodiment in conjunction with the 

5 attached Drawings, in which: 
6 

7 Figure 1 is a block diagram of a distributed computer system used in performing the 

8 method of the present invention, forming part of the apparatus of the present invention, and 

9 which may use the computer program product and article of manufacture comprising a 

10 computer-readable storage medium having a computer program embodied in said medium 

1 1 which may cause the computer system to practice the present invention; 

\S:i Figure 2 is a block diagram of an application server and a user workstation preferred in 

14! y carrying out a preferred embodiment of the present invention; and 

15fjj 

16H Figure 3 and Figure 4 are flowcharts of method steps preferred in carrying out a 

17s preferred embodiment of the present invention. 
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1 DESCRIPTION OF THE PREFERRED EMBODIMENT 

2 

3 An embodiment of the invention is now described with reference to the figures where 

4 like reference numbers indicate identical or functionally similar elements. Also in the figures, 

5 the left most digit of each reference number corresponds to the figure in which the reference 

6 number is first used. While specific configurations and arrangements are discussed, it should 

7 be understood that this is done for illustrative purposes only. A person skilled in the relevant art 

8 will recognize that other configurations and arrangements can be used without departing from 

9 the spirit and scope of the invention. It will be apparent to a person skilled in the relevant art 
10 that this invention can also be employed in a variety of other devices and applications. 

11 

12?*% With reference now to the figures, and in particular with reference to Fig. 1, there is 

13M depicted a pictorial representation of a distributed computer system 8 which may be utilized to 

14" fl implement the method of, system for, article of manufacture, and computer program product of 

I5ei the present invention. As may be seen, distributed computer system 8 may include a plurality 

Iff* °f networks 10 and 32, which may be Local Area Networks (LAN), intranet networks, or 

Yh internet networks, each of which preferably includes a plurality of individual computers 12 and 

l$h 30, respectively. Of course, those skilled in the art will appreciate that a plurality of Intelligent 

1<|" Work Stations (IWS) coupled to a host processor may be utilized for each such network. 
2d 3 

21 As is common in such data processing systems, each individual computer may be 

22 coupled to a storage device 14 and/or a printer/output device 16. One or more such storage 

23 devices 14 may be utilized, in accordance with the present invention, to store the various 

24 computer programs which may be accessed and executed by a user within the distributed 

25 computer system 8, in accordance with the present invention. In a manner well known in the 

26 prior art, each such computer program may be stored within a storage device 14. 
27 

28 Still referring to Fig. 1, it may be seen that distributed computer system 8 may also 

29 include multiple mainframe computers, such as mainframe computer 18, which may be 
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1 preferably coupled to Local Area Network 10 by means of communication link 22. Mainframe 

2 computer 18 may also be coupled to a storage device 20 which may serve as remote storage for 

3 Local Area Network 10 which may be coupled via communications controller 26 and 

4 communications link 34 to a gateway server 28. Gateway server 28 is preferably an individual 

5 computer or Intelligent Work Station which serves to link Local Area Network 32 to Local 

6 Area Network 10. 
7 

8 As discussed above with respect to Local Area Network 32 and Local Area Network 10, 

9 a plurality of server computer programs may be stored within storage device 20 and executed 

10 by mainframe computer 18. Similarly, a plurality of client computer programs may be stored 

1 1 within storage devices 14 and executed by individual computers 12 such that distributed 
12? 1 client/server computer programs are provided. Of course, those skilled in the art will 

l%n appreciate that the mainframe computer 18 may be located a great geographical distance from 

l40 Local Area Network 10, and similarly, Local Area Network 10 may be located a substantial 

133 distance from Local Area Network 32. That is, Local Area Network 32 may be located in 

l(f j California while Local Area Network 10 may be located within Texas and mainframe computer 

17 18 may be located in New York. 

im 

l4u As will be appreciated upon reference to the foregoing, it is desirable for a user of a 

2(J:f workstation 12 to be able to remotely install an application program from server 18. A 

21 configuration of the application program corresponding to this particular user of the application 

22 program is defined and stored on a remote storage 20 of the remote server 18. In response to a 

23 user request communicated from the user workstation 12 to the server 18 via LAN 10 and 

24 communications link 22, the server 18 determines that the configuration stored on storage 20 

25 corresponds to the requesting user. Server 18 authenticates the user, and after such 

26 authentication, data is downloaded to the workstation 12 from the remote server 18 according 

27 to the stored configuration. This stored configuration is also encrypted and stored in a manifest 

28 file which is also downloaded. Responsive to the user authentication, the manifest file is 

29 decrypted, and the application program is constructed, configured, and installed on workstation 
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1 12 pursuant to the configuration decrypted from the manifest file. The user may also move 

2 from a first workstation 12 on which the application program is installed to a different second 

3 workstation 12 on LAN 10 and still be able to access the user's tools and data which may be 

4 downloaded and installed on the second workstation 12 in a similar fashion to the download 

5 and installation on the first workstation 12. Using the user configurations and authentications 

6 stored on storage 20 and the server 18, a customer may control the application programs, the 

7 versions of these application programs, and resources that are available to the particular user. 
8 

9 The customer may also inventory the application programs (including versions) 

10 installed and used on a workstation 12 or a group of workstations 12 on LAN 10 without the 

1 1 need to go to each user workstation. An application program provider may also want for 
123 licensing purposes such an inventory which may be produced by customer's server 18 or the 
1 3f S provider' s server 26. 

lfl 
153 

l^ ; 1 Referring now to Figure 2, a block diagram of a preferred embodiment of the present 

17: invention is illustrated. A file known as a manifest file or manifest 244 provides a description 

180 as to which plugins, configurations, and other resources should be loaded when an application 

lSjh i program, such as an Integrated Development Environment (IDE), is initialized. Although the 

2C| :f preferred embodiment is presented in the context of an IDE, those skilled in the art will 

21 recognize that the invention may be practiced with other types of application programs. The 

22 preferred embodiment uses this manifest to provide a mechanism for plugging in tools or 

23 components to provide a customized application program with the appropriate viewers, editors, 

24 browsers, and other resources to support the user's needs. For example, a customized IDE 

25 may be provided with the appropriate viewers, editors, and browsers to support a specific 

26 developer's needs. Furthermore, the preferred embodiment allows remote customization and 

27 configuration of the application program for an individual user based on the user's role and 

28 responsibility in an organization. 
29 
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1 The preferred embodiment of the present invention comprises an application server 

2 202, which may be behind a web server, that is used to define users 204, 206, and 208 in a user 

3 table 210 and to define the users' application program configurations (214, 216, and 218) in a 

4 user IDE configuration table 220. This configuration may include plugins 222 to be 

5 downloaded , user authorizations for each user 224, templates for builds 226 (pre packaged 

6 site JCL), location/configuration of site servers 228, other information 230 such as the location 

7 and configuration of system input/output (I/O), and any site specific documentation 232 which 

8 may be shown in a browser or plugin. 
9 

10 A security system 234, such as a certificate or simple a logon dialog, may be used by a 

1 1 user to initiate a session 236 with the server 202. Upon authentication of the user by the 
12f ! j security system 234, a table lookup of the user table 210 is performed and plugins 222, 
13^i authorizations 224, templates 226, server information 228, and documentation 232 are 

140 aggregated into the user's components 238 which are downloaded via the download 240 to the 

15q user's workstation 242. In addition, a manifest 244 is created with this configuration 

Iff "I information. This manifest 244 is encrypted and requires authentication from a security system 

IT 246 on the workstation 242 to be decrypted and used to build 248 an application program 250. 

18p 

1ft i s After the download 240 to the user's workstation 242, the user through a local logon in 

20M the security system 246 invokes the decryption and use of the manifest 244 to build 248 the 

21 user's personalized application program 250. Meanwhile a request may be sent, preferably 

22 unknown to the user, to the server 202 to check a component configuration table 252 

23 maintained in the application server 202 to determine if any items have been updated. 

24 Alternatively, a request may be sent to the server 202 to record in a components inventory 254 

25 which tools are being used by the user. 
26 

27 Referring now to Figures 3 and 4, the flowcharts 300 and 400 illustrate the operations 

28 preferred in carrying out the preferred embodiment of the present invention. In the flowcharts, 

29 the graphical conventions of a diamond for a test or decision and a rectangle for a process or 
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1 function are used. These conventions are well understood by those skilled in the art, and the 

2 flowcharts are sufficient to enable one of ordinary skill to write code in any suitable computer 

3 programming language. 
4 

5 After the start 305 of the process 300, process block 310 defines a configuration of the 

6 application corresponding to a particular user 206 of the application, such as user 2, and 

7 process block 315 then stores the configuration 216 on a remote server 202 executing on a 

8 remote data processing system 18. Alternatively, the configuration 216 may be stored on 

9 local data processing system 242. Thereafter, process block 320 may initiate a session between 

10 the local data processing system 242 and the application server 202 on remote data processing 

1 1 system 18 in response to the user 206 requesting the application. Responsive to this user 

12? request, process block 325 authenticates the user 206, and process block 330 then determines 

13':^ that the stored configuration 216 corresponds to the requesting user 206. Process block 335 

14C0 then downloads data 240 from the remote data processing system 202 to the local data 

15^ processing system 242 according to the stored configuration 216. Alternatively, process block 

16H 335 may access the data 240 from the local data processing system 242 or from another 

17s resource within the distributed computer system 8 according to the stored configuration 216. 

1&: 3 Thereafter, processing continues to decision block 450 on Figure 4. This processing path is 

19i=is illustrated by flowchart connectors A, 340 on Figure 3 and 445 on Figure 4. Process block 

2CM 450 encrypts the stored configuration 216 into a manifest file 244 which is then downloaded by 

21 process block 455 from the remote data processing system 202 to the local data processing 

22 system 242. Alternatively, process block 450 may encrypt the stored configuration 216 into a 

23 manifest file 244 which is then stored on the local data processing system 242. After the 

24 download 240 of the manifest file 244 and the components 238 to the user workstation 242, the 

25 user 206 may request a build 248 of the downloaded components 238 pursuant to the 

26 configuration in the manifest file 244. Responsive to such a user request, the user is 

27 authenticated by process block 460, and if the user 206 is authenticated, then process block 465 

28 decrypts the manifest file 244. Thereafter, process block 470 builds, installs, and configures 

29 the application program 250 pursuant to the configuration decrypted from the manifest file 244. 

STL920000062US1 13 



1 The process then ends at process block 475. 
2 

3 In an alternative embodiment of the present invention, an application program is 

4 updated for execution on the data processing system. In this alternative embodiment, process 

5 block 330 also determines if any items described in the configuration have been updated. If an 

6 item has been updated, then process block 335 retrieves the updated item, and process block 

7 470 builds the application program with the updated item. 
8 

9 In still another alternative embodiment of the present invention, an application program 

10 is updated for execution on the data processing system based upon determining if any items 

1 1 described in the decrypted configuration have been updated. In this alternative embodiment, 
12h process block 465 also determines if any items described in the decrypted configuration have 
lirf been updated. If an item has been updated, then process block 470 retrieves the updated item 
14.3 and builds the application program with the updated item. 

15fJ 

16n Using the foregoing specification, the invention may be implemented using standard 

17s programming and/or engineering techniques using computer programming software, firmware, 

18f 3 hardware or any combination or sub-combination thereof. Any such resulting program(s), 

19E™ having computer readable program code means, may be embodied within one or more 

2(1 3 computer usable media such as fixed (hard) drives, disk, diskettes, optical disks, magnetic tape, 

21 semiconductor memories such as Read-Only Memory (ROM), Programmable Read-Only 

22 Memory (PROM), etc., or any memory or transmitting device, thereby making a computer 

23 program product, i.e., an article of manufacture, according to the invention. The article of 

24 manufacture containing the computer programming code may be made and/or used by 

25 executing the code directly or indirectly from one medium, by copying the code from one 

26 medium to another medium, or by transmitting the code over a network. An apparatus for 

27 making, using, or selling the invention may be one or more processing systems including, but 

28 not limited to, central processing unit (CPU), memory, storage devices, communication links, 

29 communication devices, servers, input/output (I/O) devices, or any sub-components or 
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1 individual parts of one or more processing systems, including software, firmware, hardware or 

2 any combination or sub-combination thereof, which embody the invention as set forth in the 

3 claims. User input may be received from the keyboard, mouse, pen, voice, touch screen, or any 

4 other means by which a human can input data to a computer, including through other programs 

5 such as application programs, databases, data sets, or files. 
6 

7 One skilled in the art of computer science will easily be able to combine the software 

8 created as described with appropriate general purpose or special purpose computer hardware to 

9 create a computer system and/or computer sub-components embodying the invention and to 

10 create a computer system and/or computer sub-components for carrying out the method of the 

1 1 invention. Although the present invention has been particularly shown and described with 

12 : ^ reference to a preferred embodiment, it should be apparent that modifications and adaptations 

13*3 to that embodiment may occur to one skilled in the art without departing from the spirit or 

14? q scope of the present invention as set forth in the following claims. 
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CLAIMS 

We claim: 



1 L An article of manufacture for use in a data processing system for installing an 

2 application program for execution on the data processing system, said article of manufacture 

3 comprising a computer-readable storage medium having a computer program embodied in said 

4 medium which causes the data processing system to execute the method steps comprising: 

5 defining a configuration of the application program corresponding to a particular 

6 user of the application program; 

7=..^ encrypting and storing the configuration in a manifest file; 

SfQ determining that the stored configuration corresponds to the user; 

<j=4 authenticating the user in response to the user requesting the application 

ia program; 

1 1 ™ decrypting the manifest file in response to the user authentication; and 

if building the application program pursuant to the configuration decrypted from 

1 3 the manifest file . 
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1 2. The article of manufacture of claim 1 wherein the data processing system is a local data 

2 processing system, and wherein the computer program embodied in said medium causes the 

3 data processing system to execute the additional method steps comprising: 

4 storing the configuration on a remote server executing on a remote data 

5 processing system; 

6 initiating a session between the local data processing system and the remote data 

7 processing system in response to the user requesting the local application program; 

8 responsive to the user authentication, downloading data from the remote data 
$u processing system to the local data processing system according to the stored 

163 configuration; and 

1 downloading the manifest file from the remote data processing system to the 

li J local data processing system. 

f * 3. The article of manufacture of claim 2 wherein the computer program embodied in said 

23 medium causes the data processing system to execute the additional method steps comprising: 

3 authenticating the user in a second authentication responsive to the user 

4 requesting a build of the application program; 

5 decrypting the manifest file responsive to the second authentication; and 

6 building the application program pursuant to the configuration decrypted from 

7 the manifest file responsive to the second authentication. 
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4. The article of manufacture of claim 1 wherein the computer program embodied in said 
medium causes the data processing system to execute the additional method step comprising: 

recording a description of which items are being used by the user. 

5. The article of manufacture of claim 4 wherein the recorded description is used for 
administering licensing of the items. 

6. The article of manufacture of claim 2 wherein the remote server is a web server. 

7. The article of manufacture of claim 1 wherein the configuration comprises data 
describing the user, the user's application program configuration, and resources for which the 
user is authorized. 
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1 8. A method of installing an application program for execution on a data processing 

2 system, said method comprising the steps of: 

3 

4 defining a configuration of the application program corresponding to a particular 

5 user of the application program; 

6 encrypting and storing the configuration in a manifest file; 

7 determining that the stored configuration corresponds to the user; 

8 authenticating the user in response to the user requesting the application 
?U program; 

\6q decrypting the manifest file in response to the user authentication; and 

1 ll J building the application program pursuant to the configuration decrypted from 

\\ the manifest file. 
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1 9. The method of claim 8 further comprising the steps of: 

2 storing the configuration on a remote server executing on a remote data 

3 processing system; 

4 initiating a session between the local data processing system and the remote data 

5 processing system in response to the user requesting the local application program; 

6 responsive to the user authentication, downloading data from the remote data 

7 processing system to the local data processing system according to the stored 

8 configuration; and 

9 3 downloading the manifest file from the remote data processing system to the 
1 qrg local data processing system. 

L 10. The method of claim 9 further comprising the steps of: 

authenticating the user in a second authentication responsive to the user 

J : 1 requesting a build of the application program; 

4 decrypting the manifest file responsive to the second authentication; and 

5 building the application program pursuant to the configuration decrypted from 

6 the manifest file responsive to the second authentication. 

1 11. The method of claim 8 further comprising the step of: 

2 recording a description of which items are being used by the user. 
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12. The method of claim 1 1 wherein the recorded description is used for administering 
licensing of the items. 

13. The method of claim 9 wherein the remote server is a web server. 

14. The method of claim 8 wherein the configuration comprises data describing the user, 
the user's application program configuration, and resources for which the user is authorized. 
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1 15. A computer system for installing an application program for execution on a data 

2 processing system, said computer system comprising: 

3 a configuration of the application program corresponding to a particular user of 

4 the application program; 

5 a manifest file comprising an encrypted configuration; 

6 a determination that the stored configuration corresponds to the user; 

7 an authentication of the user in response to the user requesting the application 
8~ program; 

f o a decryptor for decrypting the manifest file in response to the user 

10i authentication; and 

1 1 an application program builder for building the application program pursuant to 

1 2=i the configuration decrypted from the manifest file. 
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1 16. The computer system of claim 15 wherein the data processing system is a local data 

2 processing system, said computer system further comprising: 

3 a remote server executing on a remote data processing system in which the 

4 configuration is stored; 

5 a session between the local data processing system and the remote data 

6 processing system in response to the user requesting the local application program; 

7 a downloader, responsive to the user authentication, for downloading data from 

8 the remote data processing system to the local data processing system according to the 
9~ stored configuration; and 

iff! a downloaded manifest file which is downloaded from the remote data 

1 hi processing system to the local data processing system. 

jk 17. The computer system of claim 16 further comprising: 

|;j a second authentication of the user responsive to the user requesting a build of 

3" the application program; 

4 a second decryptor, responsive to the second authentication, for decrypting the 

5 manifest file; and 

6 an application program builder, responsive to the second authentication, for 

7 building the application program pursuant to the configuration decrypted from the 

8 manifest file. 
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18. The computer system of claim 15 further comprising a recording of a description of 
which items are being used by the user, 

19. The computer system of claim 18 wherein the recorded description is used for 
administering licensing of the items. 

20. The computer system of claim 16 wherein the remote server is a web server. 

21. The computer system of claim 15 wherein the configuration comprises data describing 
the user, the user's application program configuration, and resources for which the user is 
authorized. 
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1 ABSTRACT 

2 

3 METHOD, SYSTEM, COMPUTER PROGRAM PRODUCT, AND ARTICLE OF 

4 MANUFACTURE FOR INSTALLATION AND CONFIGURATION OF A COMPUTER 

5 PROGRAM ACCORDING TO A STORED CONFIGURATION 

6 

7 Remote installation of an application program is provided via a configuration of the 

8 application program corresponding to a particular user of the local application. The 

9 configuration is defined and stored on a remote server. In response to a user request, a 

10 determination is made that the stored configuration corresponds to the requesting user, the user 

1 1 is authenticated, and data is downloaded from the remote server according to the stored 

12=. configuration. This stored configuration is also encrypted and stored in a manifest file which is 

133 also downloaded. Responsive to the user authentication, the manifest file is decrypted, and the 

14 □ application program is constructed pursuant to the configuration decrypted from the manifest 

l|2 file. 
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